<template>
    <div class="tool-gen-edit-table">
        <el-card>
            <el-tabs v-model="activeName">
                <el-tab-pane :label="$t('gen.editTable.650980-0')" name="basic">
                    <basic-info-form ref="basicInfo" :info="info" />
                </el-tab-pane>
                <el-tab-pane :label="$t('gen.editTable.650980-1')" name="columnInfo">
                    <el-table ref="dragTable" :data="columns" row-key="columnId" :max-height="tableHeight" :border="false">
                        <el-table-column :label="$t('gen.editTable.650980-2')" type="index" min-width="55" class-name="allowDrag" />
                        <el-table-column :label="$t('gen.editTable.650980-3')" prop="columnName" align="left" min-width="140" :show-overflow-tooltip="true" />
                        <el-table-column :label="$t('gen.editTable.650980-4')" align="left" min-width="140">
                            <template slot-scope="scope">
                                <el-input v-model="scope.row.columnComment"></el-input>
                            </template>
                        </el-table-column>
                        <el-table-column :label="$t('gen.editTable.650980-5')" prop="columnType" align="center" min-width="110" :show-overflow-tooltip="true" />
                        <el-table-column :label="$t('gen.editTable.650980-6')" align="center" min-width="120">
                            <template slot-scope="scope">
                                <el-select v-model="scope.row.javaType">
                                    <el-option label="Long" value="Long" />
                                    <el-option label="String" value="String" />
                                    <el-option label="Integer" value="Integer" />
                                    <el-option label="Double" value="Double" />
                                    <el-option label="BigDecimal" value="BigDecimal" />
                                    <el-option label="Date" value="Date" />
                                    <el-option label="Boolean" value="Boolean" />
                                </el-select>
                            </template>
                        </el-table-column>
                        <el-table-column :label="$t('gen.editTable.650980-7')" align="left" min-width="120">
                            <template slot-scope="scope">
                                <el-input v-model="scope.row.javaField"></el-input>
                            </template>
                        </el-table-column>

                        <el-table-column :label="$t('gen.editTable.650980-8')" align="center" min-width="60">
                            <template slot-scope="scope">
                                <el-checkbox true-label="1" false-label="0" v-model="scope.row.isInsert"></el-checkbox>
                            </template>
                        </el-table-column>
                        <el-table-column :label="$t('gen.editTable.650980-9')" align="center" min-width="60">
                            <template slot-scope="scope">
                                <el-checkbox true-label="1" false-label="0" v-model="scope.row.isEdit"></el-checkbox>
                            </template>
                        </el-table-column>
                        <el-table-column :label="$t('gen.editTable.650980-10')" align="center" min-width="60">
                            <template slot-scope="scope">
                                <el-checkbox true-label="1" false-label="0" v-model="scope.row.isList"></el-checkbox>
                            </template>
                        </el-table-column>
                        <el-table-column :label="$t('gen.editTable.650980-11')" align="center" min-width="60">
                            <template slot-scope="scope">
                                <el-checkbox true-label="1" false-label="0" v-model="scope.row.isQuery"></el-checkbox>
                            </template>
                        </el-table-column>
                        <el-table-column :label="$t('gen.editTable.650980-12')" align="center" min-width="120">
                            <template slot-scope="scope">
                                <el-select v-model="scope.row.queryType">
                                    <el-option label="=" value="EQ" />
                                    <el-option label="!=" value="NE" />
                                    <el-option label=">" value="GT" />
                                    <el-option label=">=" value="GTE" />
                                    <el-option label="<" value="LT" />
                                    <el-option label="<=" value="LTE" />
                                    <el-option label="LIKE" value="LIKE" />
                                    <el-option label="BETWEEN" value="BETWEEN" />
                                </el-select>
                            </template>
                        </el-table-column>
                        <el-table-column :label="$t('gen.editTable.650980-13')" align="center" min-width="60">
                            <template slot-scope="scope">
                                <el-checkbox true-label="1" false-label="0" v-model="scope.row.isRequired"></el-checkbox>
                            </template>
                        </el-table-column>
                        <el-table-column :label="$t('gen.editTable.650980-14')" align="center" min-width="130">
                            <template slot-scope="scope">
                                <el-select v-model="scope.row.htmlType">
                                    <el-option :label="$t('gen.editTable.650980-15')" value="input" />
                                    <el-option :label="$t('gen.editTable.650980-16')" value="textarea" />
                                    <el-option :label="$t('gen.editTable.650980-17')" value="select" />
                                    <el-option :label="$t('gen.editTable.650980-18')" value="radio" />
                                    <el-option :label="$t('gen.editTable.650980-19')" value="checkbox" />
                                    <el-option :label="$t('gen.editTable.650980-20')" value="datetime" />
                                    <el-option :label="$t('gen.editTable.650980-21')" value="imageUpload" />
                                    <el-option :label="$t('gen.editTable.650980-22')" value="fileUpload" />
                                    <el-option :label="$t('gen.editTable.650980-23')" value="editor" />
                                </el-select>
                            </template>
                        </el-table-column>
                        <el-table-column :label="$t('gen.editTable.650980-24')" align="center" min-width="130">
                            <template slot-scope="scope">
                                <el-select v-model="scope.row.dictType" clearable filterable :placeholder="$t('pleaseSelect')">
                                    <el-option v-for="dict in dictOptions" :key="dict.dictType" :label="dict.dictName" :value="dict.dictType">
                                        <span style="float: left">{{ dict.dictName }}</span>
                                        <span style="float: right; color: #8492a6; font-size: 13px">{{ dict.dictType }}</span>
                                    </el-option>
                                </el-select>
                            </template>
                        </el-table-column>
                    </el-table>
                </el-tab-pane>
                <el-tab-pane :label="$t('gen.editTable.650980-25')" name="genInfo">
                    <gen-info-form ref="genInfo" :info="info" :tables="tables" :menus="menus" />
                </el-tab-pane>
            </el-tabs>
            <el-form label-width="100px">
                <el-form-item style="text-align: center; margin-left: -100px; margin-top: 50px">
                    <el-button type="primary" @click="submitForm()">{{ $t('submit') }}</el-button>
                    <el-button @click="close()">{{ $t('gen.editTable.650980-27') }}</el-button>
                </el-form-item>
            </el-form>
        </el-card>
    </div>
</template>

<script>
import { getGenTable, updateGenTable } from '@/api/tool/gen';
import { optionselect as getDictOptionselect } from '@/api/system/dict/type';
import { listMenu as getMenuTreeselect } from '@/api/system/menu';
import basicInfoForm from './basicInfoForm';
import genInfoForm from './genInfoForm';
import Sortable from 'sortablejs';

export default {
    name: 'GenEdit',
    components: {
        basicInfoForm,
        genInfoForm,
    },
    data() {
        return {
            // 选中选项卡的 name
            activeName: 'columnInfo',
            // 表格的高度
            tableHeight: document.documentElement.scrollHeight - 245 + 'px',
            // 表信息
            tables: [],
            // 表列信息
            columns: [],
            // 字典信息
            dictOptions: [],
            // 菜单信息
            menus: [],
            // 表详细信息
            info: {},
        };
    },
    created() {
        const tableId = this.$route.params && this.$route.params.tableId;
        if (tableId) {
            // 获取表详细信息
            getGenTable(tableId).then((res) => {
                this.columns = res.data.rows;
                this.info = res.data.info;
                this.tables = res.data.tables;
            });
            /** 查询字典下拉列表 */
            getDictOptionselect().then((response) => {
                this.dictOptions = response.data;
            });
            /** 查询菜单下拉列表 */
            getMenuTreeselect().then((response) => {
                this.menus = this.handleTree(response.data, 'menuId');
            });
        }
    },
    methods: {
        /** 提交按钮 */
        submitForm() {
            const basicForm = this.$refs.basicInfo.$refs.basicInfoForm;
            const genForm = this.$refs.genInfo.$refs.genInfoForm;
            Promise.all([basicForm, genForm].map(this.getFormPromise)).then((res) => {
                const validateResult = res.every((item) => !!item);
                if (validateResult) {
                    const genTable = Object.assign({}, basicForm.model, genForm.model);
                    genTable.columns = this.columns;
                    genTable.params = {
                        treeCode: genTable.treeCode,
                        treeName: genTable.treeName,
                        treeParentCode: genTable.treeParentCode,
                        parentMenuId: genTable.parentMenuId,
                    };
                    updateGenTable(genTable).then((res) => {
                        this.$modal.msgSuccess(res.msg);
                        if (res.code === 200) {
                            this.close();
                        }
                    });
                } else {
                    this.$modal.msgError(this.$t('gen.editTable.650980-26'));
                }
            });
        },
        getFormPromise(form) {
            return new Promise((resolve) => {
                form.validate((res) => {
                    resolve(res);
                });
            });
        },
        /** 关闭按钮 */
        close() {
            const obj = { path: '/tool/gen', query: { t: Date.now(), pageNum: this.$route.query.pageNum } };
            this.$tab.closeOpenPage(obj);
        },
    },
    mounted() {
        const el = this.$refs.dragTable.$el.querySelectorAll('.el-table__body-wrapper > table > tbody')[0];
        const sortable = Sortable.create(el, {
            handle: '.allowDrag',
            onEnd: (evt) => {
                const targetRow = this.columns.splice(evt.oldIndex, 1)[0];
                this.columns.splice(evt.newIndex, 0, targetRow);
                for (let index in this.columns) {
                    this.columns[index].sort = parseInt(index) + 1;
                }
            },
        });
    },
};
</script>

<style lang="scss" scoped>
.tool-gen-edit-table {
    padding: 20px;
}
</style>
